package com.xlhl.init.model.entity;

import com.baomidou.mybatisplus.annotation.*;
import com.xlhl.init.anno.NotSelect;
import com.xlhl.init.anno.QueryWrapperSort;
import lombok.Data;

import java.io.Serial;
import java.io.Serializable;
import java.util.Date;

/**
 * 后台管理账号表
 *
 * @author xlhl
 * @TableName account
 */
@TableName(value = "account")
@Data
public class Account implements Serializable {
    /**
     * 主键ID
     */
    @TableId(type = IdType.ASSIGN_ID)
    private Long id;

    /**
     * 账号
     */
    private String username;

    /**
     * 密码(加密存储)
     */
    private String password;

    /**
     * 昵称
     */
    private String nickname;

    /**
     * 手机号码
     */
    private String phone;

    /**
     * 角色id
     */
    private Long roleId;

    /**
     * 电子邮箱
     */
    private String email;

    /**
     * 头像URL
     */
    private String avatar;

    /**
     * 最后登录时间
     */
    private Date lastLoginTime;

    /**
     * 最后登录IP
     */
    private String lastLoginIp;

    /**
     * 是否弃用(0:不是,1:是的) {@link com.xlhl.init.model.enums.OneOrZeroEnums}
     */
    private Integer status;

    /**
     * 所属部门
     */
    private String department;

    /**
     * 创建人ID
     */
    private Long creatorId;

    /**
     * 创建人名称
     */
    private String creatorName;

    /**
     * 创建时间
     */
    @QueryWrapperSort(QueryWrapperSort.SortType.DESC)
    private Date createTime;

    /**
     * 修改时间
     */
    private Date updateTime;

    /**
     * 编辑时间
     */
    private Date editTime;

    /**
     * 逻辑删除标记(0:未删除,1:已删除)
     */
    @TableLogic
    @NotSelect
    private Integer deleted;

    @Serial
    @TableField(exist = false)
    @NotSelect
    private static final long serialVersionUID = 1L;
}